/*
  Bunny Photography — Yellow 3D Animated Theme (No JS)
  Typeface: Poppins
*/

:root{
  --yellow-50:#FFFDF3;
  --yellow-100:#FFF7CC;
  --yellow-200:#FFE97A;
  --yellow-300:#FFD84D;
  --yellow-400:#FFC61A;
  --yellow-500:#FFB400;
  --yellow-600:#E39F00;
  --ink-900:#0A0A0A;
  --ink-700:#1E1E1E;
  --ink-500:#3A3A3A;
  --white:#FFFFFF;
  --radius-xl:22px;
  --radius-lg:16px;
  --radius-md:12px;
  --shadow-3d: 0 10px 20px rgba(0,0,0,.25), 0 30px 60px rgba(0,0,0,.20);
  --shadow-soft: 0 8px 24px rgba(0,0,0,.15);
  --shadow-inset: inset 0 1px 0 rgba(255,255,255,.4), inset 0 -2px 6px rgba(0,0,0,.15);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink-900);
  background:
    radial-gradient(1200px 600px at 80% -10%, var(--yellow-100), transparent 60%),
    linear-gradient(180deg, var(--yellow-50), var(--white));
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.container{width:min(1120px, 92%); margin-inline:auto}
.section{padding:72px 0}

/* Accessibility */
.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{left:16px; top:16px; width:auto; height:auto; background:var(--yellow-400); color:var(--ink-900); padding:10px 14px; border-radius:8px}

/* Header */
.site-header{
  position:sticky; top:0; z-index:40; backdrop-filter:saturate(140%) blur(6px);
  background:linear-gradient(180deg, rgba(255,255,255,.8), rgba(255,255,255,.55));
  border-bottom:1px solid rgba(0,0,0,.06);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.nav ul{display:flex; gap:22px; list-style:none; margin:0; padding:0}
.nav a{color:var(--ink-900); text-decoration:none; font-weight:600; position:relative}
.nav a::after{content:""; position:absolute; left:0; right:0; bottom:-6px; height:3px; background:var(--yellow-500); transform:scaleX(0); transform-origin:left; transition:transform .3s ease}
.nav a:hover::after{transform:scaleX(1)}

/* Hamburger */
.menu-toggle{display:none; background:linear-gradient(180deg, var(--yellow-500), var(--yellow-600)); color:var(--ink-900); border:none; border-radius:10px; padding:10px 12px; cursor:pointer; box-shadow:var(--shadow-inset), 0 6px 14px rgba(255,180,0,.35)}
.menu-toggle .bars{display:inline-block; width:22px; height:2px; background:var(--ink-900); position:relative; vertical-align:middle}
.menu-toggle .bars::before,.menu-toggle .bars::after{content:""; position:absolute; left:0; width:22px; height:2px; background:var(--ink-900); transition:transform .25s ease, opacity .25s ease}
.menu-toggle .bars::before{top:-6px}
.menu-toggle .bars::after{top:6px}
.menu-toggle[aria-expanded="true"] .bars{background:transparent}
.menu-toggle[aria-expanded="true"] .bars::before{transform:translateY(6px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] .bars::after{transform:translateY(-6px) rotate(-45deg)}

/* Make hamburger icon bigger */
.hamburger-label {
    width: 48px;      /* Increased from typical 32px */
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.5s cubic-bezier(.68,-0.55,.27,1.55); /* Smooth rotation */
    background: none !important; /* Remove any background */
}
.hamburger-label .bars {
    width: 36px;      /* Increased from typical 24px */
    height: 4px;
    position: relative;
    transition: background 0.3s;
}
.hamburger-label .bars::before,
.hamburger-label .bars::after {
    content: '';
    position: absolute;
    width: 36px;
    height: 4px;
    transition: transform 0.3s, top 0.3s, bottom 0.3s;
}
.hamburger-label .bars::before {
    top: -12px;
}
.hamburger-label .bars::after {
    bottom: -12px;
}

/* Rotate hamburger icon 360deg when nav-toggle is checked */
.nav-toggle:checked + .hamburger-label {
    transform: rotate(360deg);
    transition: transform 0.5s cubic-bezier(.68,-0.55,.27,1.55);
}

/* Logo 3D */
.logo-3d{position:relative; display:inline-grid; perspective:800px; transform-style:preserve-3d}
.logo-3d .logo-layer{position:absolute; font-weight:800; font-size:18px; letter-spacing:.8px; color:rgba(0,0,0,.12)}
.logo-3d .layer-1{transform:translate3d(-2px,2px,-3px)}
.logo-3d .layer-2{transform:translate3d(-1px,1px,-2px)}
.logo-3d .layer-3{transform:translate3d(0,0,-1px)}
.logo-3d .logo-front{position:relative; font-weight:800; font-size:18px; background:linear-gradient(90deg, var(--yellow-600), var(--yellow-500)); -webkit-background-clip:text; background-clip:text; color:transparent}

/* Hero */
.hero{padding:80px 0 60px; position:relative}
.hero-inner{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center}
.hero-copy p{max-width:56ch; color:var(--ink-500)}
.cta-wrap{display:flex; gap:14px; margin-top:18px}

.title-3d{position:relative; line-height:1; margin:0 0 10px; display:grid}
.title-3d .shadow{grid-area:1/1; font-weight:800; font-size:clamp(36px, 6vw, 72px); color:rgba(0,0,0,.2); transform:translate3d(-6px,6px,-6px)}
.title-3d .front{grid-area:1/1; font-weight:800; font-size:clamp(36px, 6vw, 72px); color:var(--ink-900)}
.title-3d .accent{grid-area:2/1; font-weight:800; font-size:clamp(22px, 3.2vw, 40px); background:linear-gradient(90deg, var(--yellow-600), var(--yellow-500)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:1px}

.btn{appearance:none; border:none; border-radius:999px; padding:12px 18px; font-weight:700; cursor:pointer; text-decoration:none; display:inline-block}
.btn-fill{background:linear-gradient(180deg, var(--yellow-500), var(--yellow-600)); color:var(--ink-900); box-shadow: var(--shadow-inset), 0 10px 18px rgba(255,180,0,.45)}
.btn-fill:hover{filter:saturate(110%) brightness(1.02)}
.btn-ghost{background:transparent; color:var(--ink-900); box-shadow: inset 0 0 0 2px var(--yellow-400)}
.btn-ghost:hover{background:var(--yellow-100)}

.hero-card{position:relative; perspective:1200px; transform-style:preserve-3d}
.polaroid{background:var(--white); border-radius:12px; padding:10px; width:min(320px, 88%); box-shadow:var(--shadow-3d); transform:rotateY(-12deg) rotateX(8deg) translateZ(0); transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.polaroid-2{position:absolute; right:-40px; bottom:-20px; transform:rotateY(18deg) rotateX(4deg) translateZ(-40px)}
.hero-card:hover .polaroid{transform:rotateY(-6deg) rotateX(4deg) translateZ(22px)}
.hero-card:hover .polaroid-2{transform:rotateY(12deg) rotateX(2deg) translateZ(0)}
.polaroid-photo{height:220px; border-radius:8px; box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}
.polaroid-label{text-align:center; font-weight:700; color:var(--ink-700); padding-top:8px}

/* Hero section image container */
.hero-visual,
.hero-img-container {
    width: 420px;
    max-width: 95vw;
    height: 340px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(255, 214, 0, 0.13), 0 2px 8px rgba(0,0,0,0.07);
    background: #fff;
    margin: 0 auto;
}

.hero-visual img,
.hero-img-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 22px;
}

/* Responsive for mobile */
@media (max-width: 700px) {
    .hero-visual,
    .hero-img-container {
        width: 98vw;
        height: 180px;
        border-radius: 14px;
    }
    .hero-visual img,
    .hero-img-container img {
        border-radius: 14px;
    }
}

/* Placeholders (replace with real photos if available) */
.placeholder{background-size:cover; background-position:center; border-radius:12px; position:relative; overflow:hidden}
.placeholder::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(0,0,0,.08))}
.placeholder-1{background-image:url(image/placeholder.png)}
.placeholder-2{background-image:url(image/placeholder.png)}
.placeholder-3{background-image:url(image/placeholder.png)}
.placeholder-4{background-image:url(image/placeholder.png)}
.placeholder-5{background-image:url(image/placeholder.png)}
.placeholder-6{background-image:url(image/placeholder.png)}
.placeholder-7{background-image:url(image/placeholder.png)}
.placeholder-8{background-image:url(image/placeholder.png)}

/* Gallery */
.gallery-section h2{margin:0 0 18px}
.gallery-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:18px}
.card-3d{background:var(--white); border-radius:var(--radius-lg); box-shadow:var(--shadow-soft); padding:10px; transform-style:preserve-3d; transition: transform .35s ease, box-shadow .35s ease}
.card-3d .img{height:220px; border-radius:10px}
.card-3d figcaption{padding:10px 6px 6px; font-weight:600}
.card-3d:hover{transform:translateY(-6px) rotateX(2deg) rotateY(-2deg); box-shadow:0 14px 30px rgba(0,0,0,.18)}

/* About */
.about-grid{display:grid; grid-template-columns: 1fr 1.1fr; gap:36px; align-items:center}
.card-thick{background:var(--white); border-radius:var(--radius-xl); padding:16px; box-shadow: var(--shadow-3d)}
.layered-frame {
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--yellow-100), var(--yellow-300));
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.layered-frame::before,.layered-frame::after{content:""; position:absolute; inset:10px; border-radius:14px; box-shadow:inset 0 0 0 2px rgba(0,0,0,.06)}
.frame-inner {
    position: absolute;
    inset: 10px;  /* Changed from 20px to 10px for better fit */
    border-radius: 12px;
    overflow: hidden;
    background: none;
}
.frame-inner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 12px;
    transition: transform 0.3s ease;
}

.frame-inner:hover img {
    transform: scale(1.05);
}

/* Remove placeholder background for About section images */
.about-visual .placeholder {
  background: none !important;
}
.about-visual .placeholder::after {
  display: none !important;
}
.ticks{list-style:none; padding:0; margin:16px 0 22px}
.ticks li{margin:6px 0; padding-left:26px; position:relative}
.ticks li::before{content:"✔"; position:absolute; left:0; color:var(--yellow-600); font-weight:800}

/* Services */
.services-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap:18px}
.service-card{padding:18px}
.service-card h3{margin:0 0 8px}
.service-card p{margin:0 0 12px; color:var(--ink-500)}
.service-card .price{font-weight:800; color:var(--ink-900)}

/* Contact */
.contact-grid{display:grid; grid-template-columns: .9fr 1.1fr; gap:24px; align-items:start}
.contact-form{background:var(--white); border-radius:var(--radius-lg); padding:18px; box-shadow:var(--shadow-soft)}
.form-row{display:flex; flex-direction:column; gap:8px; margin-bottom:12px}
label{font-weight:700}
input, textarea{font-family:inherit; border:1px solid rgba(0,0,0,.12); border-radius:10px; padding:12px 14px; outline:none; transition:border-color .2s ease, box-shadow .2s ease; background:var(--yellow-100)}
input:focus, textarea:focus{border-color:var(--yellow-400); box-shadow:0 0 0 4px rgba(255,198,26,.25)}

/* Footer */
.site-footer{padding:26px 0; border-top:1px solid rgba(0,0,0,.06); background:linear-gradient(180deg, rgba(255,255,255,.75), rgba(255,255,255,.6))}
.footer-inner{display:flex; align-items:center; justify-content:space-between}
.footer-brand{display:flex; align-items:center; gap:10px; font-weight:800}
.bunny-mark{filter:drop-shadow(0 4px 6px rgba(0,0,0,.2))}

/* Animations */
@keyframes floaty{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}
@keyframes sheen{0%{transform:translateX(-120%)}100%{transform:translateX(220%)}}
.polaroid,.service-card,.card-thick{animation:floaty 7s ease-in-out infinite}
.polaroid-2{animation-duration:8.5s}
.card-3d .img::before{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(255,255,255,.0), rgba(255,255,255,.55), rgba(255,255,255,0)); transform:translateX(-120%); animation:sheen 5s linear infinite}

/* Responsiveness */
@media (max-width: 980px){
  .menu-toggle{display:inline-flex; align-items:center; gap:8px}
  .nav{position:fixed; top:0; right:0; bottom:0; width:min(84vw, 340px); background:linear-gradient(180deg, rgba(255,255,255,.97), rgba(255,255,255,.92)); box-shadow:-30px 0 60px rgba(0,0,0,.25); transform:translateX(100%); transition:transform .35s ease; padding:80px 20px 20px; backdrop-filter:saturate(160%) blur(8px); z-index:50}
  .nav ul{flex-direction:column; gap:18px}
  body.nav-open .nav{transform:translateX(0)}
  body.nav-open{overflow:hidden}
  .hero-inner{grid-template-columns:1fr}
  .hero-card{order:-1; margin-bottom:16px}
  .gallery-grid{grid-template-columns:repeat(2, 1fr)}
  .about-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .nav ul{gap:12px}
  .nav a{padding:12px 6px; display:block}
  .gallery-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .title-3d .front{font-size:42px}
  .title-3d .shadow{font-size:42px}
  .title-3d .accent{font-size:22px}
  .hero-card{transform:scale(1.12); transform-origin: top center; margin-left:auto; margin-right:auto}
  .polaroid{width:100%}
  .polaroid-photo{height:auto; aspect-ratio: 4 / 3}
  .card-3d .img{height:auto; aspect-ratio: 4 / 3}
  .section{padding:56px 0}
}

/* JS reveal hooks */
.reveal{opacity:0; transform: translateY(16px) scale(.98); transition:opacity .6s ease, transform .6s ease}
.reveal.reveal-in{opacity:1; transform: translateY(0) scale(1)}

/* Overlay mobile nav (checkbox driven) */
.nav-toggle{display:none}
.hamburger-label{display:none}
.mobile-nav-overlay{position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,.3); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); z-index:55; display:flex; justify-content:center; align-items:flex-start; transition:opacity .3s ease, visibility .3s ease; opacity:0; visibility:hidden}
.mobile-nav{background:rgba(255,255,255,.75); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); width:90%; max-width:360px; margin-top:5rem; padding:1.6rem 1.2rem; box-shadow:0 20px 40px rgba(0,0,0,.2); border-radius:20px; border:1px solid rgba(255,255,255,.6); transform:translateY(-20px) scale(.95); transition:transform .3s ease, opacity .3s ease; opacity:0}
.mobile-nav ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.5rem}
.mobile-nav ul li a{color:var(--ink-900); text-decoration:none; font-size:1.05rem; padding:1rem 1.25rem; display:block; border-radius:15px; transition:all .3s ease; background:rgba(255,255,255,.6); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:1px solid rgba(0,0,0,.08); margin-bottom:.75rem; text-align:center}
.mobile-nav ul li a:hover{color:var(--ink-900); background:rgba(255,196,26,.15); border-color:rgba(255,196,26,.35); transform:translateY(-2px); box-shadow:0 4px 15px rgba(255,180,0,.25)}
.mobile-nav .btn-primary{background:linear-gradient(135deg, var(--yellow-500), var(--yellow-600)); color:#000; padding:1.1rem 1.2rem; border-radius:15px; font-weight:800; text-decoration:none; transition:all .3s ease; display:block; text-align:center; margin-top:1.2rem; box-shadow:0 4px 15px rgba(255,180,0,.3); font-size:1.05rem}
.mobile-nav .btn-primary:hover{background:linear-gradient(135deg, var(--yellow-600), var(--yellow-500)); transform:translateY(-2px); box-shadow:0 8px 24px rgba(255,180,0,.4)}

@media (max-width: 980px){
  .menu-toggle{display:none}
  .hamburger-label{display:inline-flex; align-items:center; justify-content:center; width:48px; height:44px; border-radius:12px; background:transparent; cursor:pointer}
  .hamburger-label .bars{width:32px; height:32px; background-image:url('image/menu-icon.png'); background-size:contain; background-repeat:no-repeat; background-position:center}
  .nav-toggle:checked ~ .mobile-nav-overlay{opacity:1; visibility:visible}
  .nav-toggle:checked ~ .mobile-nav-overlay .mobile-nav{transform:translateY(0) scale(1); opacity:1}
}

/* Loader styles: always centered and responsive */
#loader {
    position: fixed;
    z-index: 9999;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100dvh;
    min-width: 100vw;
    width: 100vw;
    height: 100dvh;
    transition: opacity 0.4s;
    gap: 24px;
}
#loader img {
    max-width: 80vw;
    max-height: 80px;
    width: auto;
    height: 64px;
    object-fit: contain;
}
.loader-spinner {
    width: 40px;
    height: 40px;
    border: 4px solid #FFD600;
    border-top: 4px solid #fff;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
@media (max-width: 600px) {
    #loader img {
        max-height: 48px;
        height: 40px;
    }
    .loader-spinner {
        width: 28px;
        height: 28px;
        border-width: 3px;
    }
}
@keyframes spin {
    to { transform: rotate(360deg); }
}
body.loaded #loader {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s;
}

/* Gallery and general image styling */
.gallery-grid,
.gallery-section,
.gallery-row {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
}

.gallery-item {
    width: 320px;
    height: 220px;
    background: #f8f8f8;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 4px 18px rgba(0,0,0,0.07);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.gallery-item img,
img.gallery-img,
img.cover-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 18px;
    transition: transform 0.3s;
}

.gallery-item img:hover,
img.gallery-img:hover,
img.cover-img:hover {
    transform: scale(1.04);
}

/* Responsive for mobile */
@media (max-width: 600px) {
    .gallery-grid {
        grid-template-columns: 1fr; /* 1 column for mobile */
    }
    .gallery-item {
        width: 98vw;
        max-width: 340px;
        height: 180px;
    }
}

/* For other image sections (about, services, etc.) */
.section img,
.card-3d img,
.card-thick img,
.polaroid img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 14px;
    display: block;
}

@media (max-width: 600px) {
    .section img,
    .card-3d img,
    .card-thick img,
    .polaroid img {
        height: 100%;
    }
}

/* Gallery grid: 3 columns on large screens, 2 on laptop/tablet, 2 on mobile */
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* Default: 3 columns */
    gap: 18px;
}

@media (max-width: 1200px) {
    .gallery-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 columns for laptop/tablet */
    }
}

@media (max-width: 600px) {
    .gallery-grid {
        grid-template-columns: 1fr; /* 1 column for mobile */
    }
}

