.client-portal-page{--gallery-ink: #191715;--gallery-muted: #6d6962;--gallery-hairline: #ddd9d1;--gallery-paper: #f7f6f3;--gallery-panel: rgba(247, 246, 243, .96);--gallery-charcoal: #191715;--gallery-signature: #b8a47a;--gallery-signature-rgb: 184, 164, 122;position:relative;background:var(--gallery-paper);color:#1c1917;font-family:var(--font-body, "Inter"),sans-serif}.client-portal-page:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:var(--film-grain);background-size:120px 120px;opacity:.16;mix-blend-mode:multiply}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading, "Outfit"),sans-serif}.client-shell{position:relative;z-index:1;padding-bottom:118px}.client-topbar{border-bottom:1px solid var(--gallery-hairline);background:#f7f6f3eb;backdrop-filter:blur(14px)}.client-topbar .brand{font-family:Playfair Display,Georgia,serif;font-size:1.06rem;font-weight:600;letter-spacing:0;text-transform:none}.client-gallery-status{display:flex;align-items:center}.client-topbar .badge{min-height:auto;gap:8px;padding:0;border:0;background:transparent;color:#19171594;font-size:.64rem;font-weight:760;letter-spacing:.18em;line-height:1;text-transform:uppercase}.client-topbar .badge:before{content:"";width:5px;height:5px;border-radius:999px;background:rgba(var(--gallery-signature-rgb),.9);box-shadow:0 0 0 3px rgba(var(--gallery-signature-rgb),.12)}.client-container{max-width:1280px;margin:58px auto 0;padding:0 clamp(20px,4vw,52px)}.gallery-welcome{margin-bottom:56px;text-align:center;max-width:920px;margin-inline:auto}.gallery-welcome h1{font-family:Playfair Display,Georgia,serif;font-size:clamp(2.7rem,5vw,4.7rem);font-weight:600;line-height:.96;letter-spacing:0;margin-bottom:18px;color:var(--gallery-ink)}.intro-paragraph{max-width:540px;margin:0 auto;color:var(--gallery-muted);font-size:.76rem;font-weight:650;line-height:1.7;letter-spacing:.16em;text-transform:uppercase}.instruction-box{display:none}.download-banner{background:#ecfdf5;border:1px solid #a7f3d0;border-radius:12px;padding:20px;margin-top:30px;display:flex;justify-content:space-between;align-items:center;text-align:left;gap:16px;box-shadow:0 4px 16px #10b98114}.banner-content{display:flex;align-items:center;gap:16px}.banner-icon{font-size:2.2rem}.download-banner h3{margin:0 0 4px;font-size:1.1rem;color:#065f46}.download-banner p{margin:0;font-size:.88rem;color:#047857}.portal-toolbar{position:fixed;left:50%;bottom:18px;z-index:90;display:flex;justify-content:space-between;align-items:center;width:min(calc(100% - 32px),920px);min-height:58px;padding:9px 10px 9px 20px;border:1px solid rgba(25,23,21,.18);border-radius:999px;background:var(--gallery-charcoal);color:#fff;box-shadow:0 14px 38px #1917152e;opacity:0;pointer-events:none;transform:translate(-50%,22px);transition:opacity .18s ease,transform .18s ease}.portal-toolbar.has-selection{opacity:1;pointer-events:auto;transform:translate(-50%)}.selection-status{color:#ffffffd6;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.selection-status strong{color:#fff;font-weight:850}.toolbar-actions{display:flex;gap:8px}.selection-view-toggle{min-width:138px}.portal-toolbar .button{min-height:38px;padding:8px 16px;border-radius:999px;font-size:.82rem}.portal-toolbar .button-secondary{border-color:#fff3;background:transparent;color:#ffffffc7}.portal-toolbar .button-action{border-color:#fff;background:#fff;color:var(--gallery-charcoal);box-shadow:none}.portal-toolbar .button[hidden]{display:none}.client-portal-page #modal-btn-confirm{border-color:var(--gallery-charcoal);background:var(--gallery-charcoal);color:#fff;box-shadow:none}.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:clamp(24px,3vw,36px)}@media(hover:hover)and (pointer:fine){.client-grid.is-focusing .client-tile:not(.is-active){opacity:.84;filter:saturate(.94) contrast(.99)}}.client-tile{position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden;background:#ebe8e1;border:1px solid rgba(25,23,21,.08);outline:1px solid transparent;outline-offset:2px;box-shadow:none;cursor:zoom-in;transition:opacity .52s ease,filter .52s ease,transform .22s ease,outline-color .22s ease,border-color .22s ease,box-shadow .22s ease;animation:galleryTileEnter .62s cubic-bezier(.16,1,.3,1) both;animation-delay:calc(var(--tile-index, 0) * 50ms)}.client-tile:hover{transform:translateY(-5px) scale(1.01);border-color:#19171529;box-shadow:0 1px 1px #1917150a,0 10px 22px #19171514,0 28px 62px #19171524}.client-tile.selected-proof{border:1px solid rgba(var(--gallery-signature-rgb),.95);outline-color:rgba(var(--gallery-signature-rgb),.66);box-shadow:inset 0 0 0 1px rgba(var(--gallery-signature-rgb),.78),inset 0 0 0 4px #f7f6f357,0 16px 38px #1917151a}.client-tile.selected-proof:hover{outline-color:rgba(var(--gallery-signature-rgb),.74);box-shadow:inset 0 0 0 1px rgba(var(--gallery-signature-rgb),.84),inset 0 0 0 4px #f7f6f361,0 1px 1px #1917150a,0 10px 22px #19171517,0 30px 68px #19171529}.client-tile img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .42s ease}.client-tile:hover img{transform:scale(1.025)}.heart-btn{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:#f7f6f3eb;border:1px solid rgba(25,23,21,.1);display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 24px #1917151f;transition:transform .18s ease,background-color .18s ease,color .18s ease;color:#19171580;z-index:3}.heart-btn:hover{transform:scale(1.06);background:#fff;color:var(--gallery-charcoal)}.heart-btn.selected{color:var(--gallery-charcoal);background:#fff;transform:scale(1.05)}.heart-btn.just-selected .heart-icon{animation:heartSpring .34s cubic-bezier(.18,.89,.32,1.28)}.heart-icon{width:17px;height:17px;display:block;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}.heart-btn.selected .heart-icon,.lightbox-fav-btn.active .heart-icon{fill:currentColor}.tile-info{position:absolute;bottom:0;inset-inline:0;display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:34px 12px 12px;background:linear-gradient(to top,rgba(25,23,21,.58),transparent);color:#ffffffb8;font-size:.58rem;font-weight:720;letter-spacing:.14em;line-height:1.2;pointer-events:none;opacity:0;transition:opacity .18s ease;text-transform:uppercase;z-index:2}.tile-info span:last-child{min-width:0;overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap}.client-tile:hover .tile-info{opacity:1}.grid-loader{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;padding:60px;color:#78716c}.spinner{width:36px;height:36px;border:3px solid rgba(0,0,0,.1);border-top-color:var(--cyan);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}.lightbox{display:none;position:fixed;inset:0;z-index:100;background:#0c0c0af5;backdrop-filter:blur(8px);place-items:center;padding:40px;user-select:none}.lightbox-close{position:absolute;top:24px;right:30px;font-size:2.5rem;color:#fff;cursor:pointer;font-weight:300;z-index:102}.lightbox-content{max-width:90%;max-height:80vh;display:flex;flex-direction:column;align-items:center;position:relative}.lightbox-content img{max-width:100%;max-height:72vh;object-fit:contain;border-radius:4px;box-shadow:0 24px 64px #000c}.lightbox-caption{margin-top:20px;display:flex;align-items:center;justify-content:space-between;width:100%;color:#fff;max-width:600px}.lightbox-fav-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;cursor:pointer;font-weight:700;transition:all .2s ease}.lightbox-fav-btn.active{background:#fff;border-color:#fff;color:var(--gallery-charcoal)}.lightbox-fav-btn .heart-icon{width:18px;height:18px}.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);font-size:2.2rem;color:#fff9;cursor:pointer;padding:16px;transition:color .2s ease;z-index:101}.lightbox-arrow:hover{color:#fff}.lightbox-arrow.left{left:24px}.lightbox-arrow.right{right:24px}.selection-review-modal{width:min(calc(100vw - 32px),860px);max-height:calc(100vh - 48px);overflow:auto;padding:clamp(26px,4vw,44px);border:1px solid rgba(25,23,21,.12);border-radius:10px;background:#fffffffa;box-shadow:0 28px 80px #1917152e}.selection-review-modal .modal-kicker{margin:0 0 8px;color:#1917158f;font-size:.66rem;font-weight:760;letter-spacing:.18em;text-transform:uppercase}.selection-review-modal h3{margin:0;color:var(--gallery-ink);font-family:Playfair Display,Georgia,serif;font-size:clamp(2.1rem,5vw,3.25rem);font-weight:600;line-height:.98}.selection-review-modal .modal-subcopy{max-width:600px;margin:14px 0 0;color:var(--gallery-muted);font-size:.95rem;line-height:1.65}.selection-review-count{margin:22px 0 12px;color:#1917159e;font-size:.68rem;font-weight:760;letter-spacing:.14em;text-transform:uppercase}.selection-review-count strong{color:var(--gallery-ink)}.selection-review-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(10px,2vw,16px);margin:0 0 24px}.selection-review-grid.review-ribbon{grid-template-columns:repeat(auto-fit,minmax(116px,1fr))}.selection-review-image{aspect-ratio:4 / 5;overflow:hidden;border-radius:5px;background:#ebe8e1}.selection-review-image img{width:100%;height:100%;display:block;object-fit:cover}.retouching-notes-field{display:block;margin-top:6px}.retouching-notes-field span{display:block;margin-bottom:8px;color:#191715b8;font-size:.72rem;font-weight:760;letter-spacing:.12em;text-transform:uppercase}.retouching-notes-field em{color:#1917157a;font-style:normal;font-weight:650}.retouching-notes-field textarea{width:100%;min-height:92px;resize:vertical;border:1px solid rgba(25,23,21,.16);border-radius:8px;background:#f7f6f3b8;color:var(--gallery-ink);padding:13px 14px;font-size:.95rem;line-height:1.55}.retouching-notes-field textarea:focus{outline:1px solid rgba(var(--gallery-signature-rgb),.86);outline-offset:2px;border-color:rgba(var(--gallery-signature-rgb),.72)}.selection-review-actions{display:flex;width:100%;margin-top:22px;justify-content:space-between;align-items:center;gap:10px}.selection-review-actions .button{border-radius:999px;min-height:42px;padding-inline:18px}.selection-review-actions .button-secondary{width:auto;min-height:auto;padding:0;border:0;background:transparent;color:#1917159e;font-weight:720}.selection-review-actions .button-secondary:hover,.selection-review-actions .button-secondary:focus-visible{color:var(--gallery-ink);text-decoration:underline;text-underline-offset:4px}.selection-review-actions .button-action{margin-left:auto;border-color:var(--gallery-charcoal);background:var(--gallery-charcoal);color:#fff}@keyframes galleryTileEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes heartSpring{0%{transform:scale(1)}55%{transform:scale(1.28)}to{transform:scale(1)}}@media(prefers-reduced-motion:reduce){.client-tile,.client-tile img,.heart-btn,.heart-icon,.portal-toolbar{animation:none;transition:none}}@media(max-width:640px){.download-banner{flex-direction:column;align-items:stretch}.download-banner .button{text-align:center}.portal-toolbar{flex-direction:column;bottom:12px;width:calc(100% - 20px);gap:10px;align-items:stretch;border-radius:18px;padding:13px}.toolbar-actions{display:grid;grid-template-columns:1fr 1fr}.selection-view-toggle{grid-column:1 / -1}.selection-review-grid,.selection-review-grid.review-ribbon{grid-template-columns:repeat(2,minmax(0,1fr))}.selection-review-actions{flex-direction:column-reverse;align-items:stretch}.selection-review-actions .button-secondary{align-self:center}}
